PCF8584



## GENERAL DESCRIPTION

The PCF8584 is an integrated circuit designed in CMOS technology which serves as an interface between most standard parallel-bus microcontrollers/processors and the serial 1<sup>2</sup>C-bus. The PCF8584 provides both master and slave functions. Communication with the 1<sup>2</sup>C-bus is carried out on a byte-wise basis using interrupt or polled handshake. It controls all the 1<sup>2</sup>C-bus specific sequencing, protocol, arbitration and timing. The PCF8584 allows parallel-bus systems to communicate bidirectionally with the 1<sup>2</sup>C-bus.

#### **Features**

- Parallel-bus/l<sup>2</sup>C-bus protocol converter
- Compatible with most parallel-bus processors including MAB8049, MAB8051, SCN68000 and Z80
- Automatic selection of bus interface
- Programmable interrupt vector
- Multi-master capability
- I2C-bus monitor mode
- Long-distance mode
- Operating supply voltage 4.5 to 5.5 V
- Operating temperature range -40 to +85 °C

### **PACKAGE OUTLINES**

PCF8584P: 20-lead DIL; plastic (SOT146).

PCF8584T: 20-lead mini-pack; plastic (SO20; SOT163A).

May 1994

3-16

7110826 0076302 186



# 12C-bus controller

PCF8584



Where:

( ) indicate the SCN68000 pin name designations.

X = don't care.

Fig.1 Block diagram,

May 1994

3-17

**7110826 0076303 012** 



PCF8584

### PINNING



Where:

( ) indicate the SCN68000 pin name designations.

Fig.2 Pinning diagram.

| Pin | functions         |          |                                                                                                                                                                                                                                                                      |
|-----|-------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pin | mnemonic          | function | description                                                                                                                                                                                                                                                          |
| 1   | CLK               | 1        | Clock input from microprocessor clock generator (internal pull-up).                                                                                                                                                                                                  |
| 2   | SDA or<br>SDA OUT | 1/0      | l <sup>2</sup> C-bus serial data input/output (open-drain).<br>Serial data output in long-distance mode.                                                                                                                                                             |
| 3   | SCL or<br>SCL IN  | 1/0      | l <sup>2</sup> C-bus serial clock input/output (open-drain).<br>Serial clock input in long-distance mode.                                                                                                                                                            |
| 4   | SDA IN            | 1        | Interrupt acknowledge input (internal pull-up); when this signal is asserted the interrupt vector in Register S2 will be available at the bus port if the ENI flag is set. Serial data input in long-distance mode.                                                  |
| 5   | INT or<br>SCL OUT | 0        | Interrupt output (open-drain); this signal is enabled by the ENI flag in Register S1. It is asserted, when the PIN flag is reset. (PIN is reset after one byte is transmitted or received over the I <sup>2</sup> C-bus). Serial clock output in long-distance mode. |
| 6   | A0                | 1        | Register select input (internal pull-up); this input selects between the control/status register and the other registers. Logic 1 selects Register S1, logic 0 selects one of the other registers depending on bits loaded in ES0, ES1 and ES2 of Register S1.       |
| 7   | DB0               | 1/0      |                                                                                                                                                                                                                                                                      |
| 8   | DB1               | 1/0      | Bidirectional 8-bit bus port.                                                                                                                                                                                                                                        |
| 9   | DB2               | 1/0      |                                                                                                                                                                                                                                                                      |
| 10  | VSS               |          | Negative supply voltage.                                                                                                                                                                                                                                             |
|     |                   |          |                                                                                                                                                                                                                                                                      |

May 1994

3-18

7110826 0076304 T59 mm



Pin functions (continued)

# I<sup>2</sup>C-bus controller

19

RESET/

STROBE

PCF8584

| pin | mnemonic   | function | description                                                                                                                                                 |
|-----|------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11  | DB3        | 1/0      |                                                                                                                                                             |
| 12  | DB4        | 1/0      |                                                                                                                                                             |
| 13  | DB5        | 1/0      | Bidirectional 8-bit bus port.                                                                                                                               |
| 14  | DB6        | 1/0      |                                                                                                                                                             |
| 15  | DB7        | 1/0      |                                                                                                                                                             |
| 16  | RD (DTACK) | 1 (0)    | RD is the read control input for MAB8049, MAB8051 or Z80-type processors. DTACK is the data transfer control output for 68000-type processors (open-drain). |
| 17  | CS         | 1        | Chip select input (internal pull-up).                                                                                                                       |

18 WR (R/W) I WR is the write control input for MAB8048, MAB8051 or Z80-type processors (internal pull-up). R/W control input for 68000-type processors.

Reset input (open-drain); this input forces the I<sup>2</sup>C-bus controller into a predefined state; all flags are reset, except PIN, which is set. Also functions as strobe output.

20 V<sub>DD</sub> Positive supply voltage.

1/0

May 1994

3-19

**■ 7110826 0076305 995 ■** 



PCF8584

### **FUNCTIONAL DESCRIPTION**

#### General

The PCF8584 acts as an interface device between standard high-speed parallel buses and the serial I<sup>2</sup>C-bus. On the I<sup>2</sup>C-bus, it can act either as master or slave. Bidirectional data transfer between the I<sup>2</sup>C-bus and the parallel-bus microprocessor is carried out on a byte-wise basis, using either an interrupt or polled handshake. Interface to either 80XX-type (e.g. MAB8048, MAB8051, Z80) or 68000-type buses is possible. Selection of bus type is automatically performed (see Interface mode control).

Table 1 Control signals utilized by the PCF8584 for processor interfacing

| type       | R/W | WR  | RD  | DTACK | IACK |
|------------|-----|-----|-----|-------|------|
| MAB8049/51 | NO  | YES | YES | NO    | NO   |
| SCC68000   | YES | NO  | NO  | YES   | YES  |
| Z80        | NO  | YES | YES | NO    | YES  |
|            |     |     |     |       | 1    |

The structure of the PCF8584 is similar to that of the I<sup>2</sup>C-bus interface section of the MAB8400-series of microcontrollers, but with a modified control structure. The PCF8584 has five internal register locations. Three of these (Own Address register S0', Clock register S2 and Interrupt Vector S3) are used for initialization of the PCF8584. Normally they are only written once directly after resetting of the PCF8584. The remaining two registers function as double registers (Data Buffer/Shift register S0, and Control/Status register S1) which are used during actual data transmission/reception. By using these double registers, which are separately write and read accessible, overhead for register access is reduced. S0 is a combination of a shift register and data buffer. S0 performs all serial-to-parallel interfacing with the I<sup>2</sup>C-bus. S1 contains I<sup>2</sup>C-bus status information required for bus access and/or monitoring.

## Interface mode control (IMC)

Selection of either an 80XX-mode or 68000-mode interface is achieved by detection of the  $\overline{WR}$  -  $\overline{CS}$  signal sequence. The concept takes advantage of the fact that the write control input is common for both types of interfaces. The chip is non-initialized after reset until register S0' is accessed. An 80XX-type interface is default. If a HIGH-to-LOW transition of  $\overline{WR}$  (R/ $\overline{W}$ ) is detected while  $\overline{CS}$  is HIGH, the 68000-type interface mode is selected and the  $\overline{DTACK}$  output is enabled.

#### Note:

The very first access to the PCF8584 after a reset must be a write access to register SO' in order to set the appropriate interface mode.

May 1994

3-20

7110826 0076306 821



PCF8584

#### **FUNCTIONAL DESCRIPTION** (continued)

Set-up Registers S0', S2 and S3

Own Address Register SO'

When addressed as a slave, this register is loaded with the 7-bit I<sup>2</sup>C-bus address to which the PCF8584 is to respond. The "Addressed As Slave" (AAS) bit in Status register S1 is set when this address is received. Programming of this register is accomplished via the parallel-bus when A0 is LOW, with the appropriate bit combinations set in Control Status register S1 (S1 is written when A0 is HIGH). Bit combinations for accessing all registers are given in Tables 4 and 5. After reset S0' has default address '00' Hex.

### Clock Register S2

Register S2 provides control over chip clock frequency and SCL clock frequency. S20 and S21 provide a selection of 4 different I<sup>2</sup>C-bus SCL frequencies which are shown in Table 2.

Table 2 Register S2 selection of SCL frequency

| bit |     | SCL approximate frequency |
|-----|-----|---------------------------|
| S21 | S20 | (kHz)                     |
| 0   | 0   | 90                        |
| 0   | 1   | 45                        |
| 1   | 0   | 11                        |
| 1   | 1   | 1.5                       |

S22, S23 and S24 are used for control of the internal clock prescaler. Due to the possibility of varying microprocessor clock signals, the prescaler can be programmed to adapt to 5 different clock rates, thus providing a constant internal clock. This is required to provide a stable time base for the SCL generator and the digital filters associated with the I<sup>2</sup>C-bus signals SCL and SDA. Selection for adaption to external clock rates is shown in Table 3. After reset, a clock frequency of 12 MHz is the default value.

Table 3 Register S2 selection of clock frequency

| S24 | bit<br>  S23 | S22 | clock frequency<br>(MHz) |  |  |
|-----|--------------|-----|--------------------------|--|--|
| 0   | X            | X   | 3                        |  |  |
| 1   | 0            | 0   | 4.43                     |  |  |
| 1   | 0            | 1   | 6                        |  |  |
| 1   | 1            | 0   | 8                        |  |  |
| 1   | 1            | 1   | 12                       |  |  |

Where: X = don't care.

May 1994

3-21

7110826 0076307 768 1



PCF8584

#### Interrupt Vector S3

The interrupt vector register provides an 8-bit user-programmable vector for vectored-interrupt micro-processors. The vector is sent to the bus port when an interrupt acknowledge signal is asserted and the ENI (enable interrupt) flag is set. Default vector values are as follows:

- Vector is '00' Hex in 80XX-mode
- Vector is '0F' Hex in 68000-mode

On reset the PCD8584 is in the 80XX mode, thus the default interrupt vector becomes '00' Hex.

#### Interface Registers S0 and S1

## Data Shift Register SO

SO acts as serial shift register interfacing to the I<sup>2</sup>C-bus. SO is a combination of a shift register and a data buffer; parallel data is always written to the shift register and read from the data buffer. Serial data is shifted in/out the shift register, and in receiver mode the data from the shift register is copied to the data buffer during the acknowledge phase (see also PIN bit). All read and write operations to the I<sup>2</sup>C-bus are done via this register.

### Control/Status Register S1

Register S1 is accessed by a HIGH signal on register select input A0. To facilitate communication between the microcontroller/processor and the I<sup>2</sup>C-bus, register S1 has separate read and write functions for all bit positions.

The write-only section has been split into 2 parts:

• The ESO (Enable Serial Output) enables or disables the serial output. When ESO is LOW, register access for initialization is possible. When ESO is HIGH, serial communication is enabled; communication with serial shift register SO is enabled and the S1 bus status bits are made available for reading. Select control bits ES1 and ES2 control selection of other registers for initialization and control of normal operation. After these bits are programmed for access to the desired register (see Tables 4 and 5), the register is selected by a logic LOW level on register select pin AO.

#### Note:

With ESO = 0, bits ENI, STA, STO and ACK of S1 can be read for test purposes.

May 1994





PCF8584

### **FUNCTIONAL DESCRIPTION (continued)**

Control/Status Register S1 (continued)

Table 4 Register access control; ESO = logic 0 (serial interface off)

| ES1 | ES1         | TACK          | operation                                                     |
|-----|-------------|---------------|---------------------------------------------------------------|
| X   | x           | x -           | READ/WRITE CONTROL REGISTER (S1)<br>STATUS (S1) not available |
| 0   | 0           | ×             | READ/WRITE OWN ADDRESS (S0')                                  |
| 0   | 1           | ×             | READ/WRITE INTERRUPT VECTOR (S3)                              |
| 1   | 0           | ×             | READ/WRITE CLOCK REGISTER (S2)                                |
|     | ES1 X 0 0 1 | X X 0 0 0 0 1 | X X X 0 0 0 X 0 1 X                                           |

Table 5 Register access control; ESO = logic 1 (serial interface on)

| A0 | ES1 | ES2 | IACK | operation                                 |
|----|-----|-----|------|-------------------------------------------|
| Н  | ×   | ×   | Н    | WRITE CONTROL REGISTER (S1)               |
| Н  | X   | ×   | Н    | READ STATUS REGISTER (S1)                 |
| L  | X   | 0   | Н    | READ/WRITE DATA (SO)                      |
| L  | X   | 1   | Н    | READ/WRITE INTERRUPT VECTOR (S3)          |
| ×  | 0   | ×   | L    | READ INTERRUPT VECTOR (acknowledge cycle) |
| X  | 1   | X   | L    | long-distance mode                        |

Instruction control bits ENI, STA, STO and ACK are used in normal operation to enable the interrupt output  $(\overline{|NT})$ , generate I<sup>2</sup>C-bus START and STOP conditions, and program the acknowledge response, respectively. These possibilities are shown in Table 6.

May 1994

3-23

7330826 0076309 530



PCF8584

Table 6 Instruction table for serial bus control

| STA | STO | present mode       | function                | operation                                                                                        |
|-----|-----|--------------------|-------------------------|--------------------------------------------------------------------------------------------------|
| 1   | 0   | SLV/REC            | START                   | transmit START + address<br>remain MST/TRM if<br>R/W= logic 0; go to<br>MST/REC if R/W = logic 1 |
| 1   | 0   | MST/TRM            | REPEAT START            | same as for SLV/REC                                                                              |
| 0   | 1   | MST/REC<br>MST/TRM | STOP READ<br>STOP WRITE | transmit stop<br>go to SLV/REC mode<br>(see note 1)                                              |
| . 1 | 1   | MST                | DATA CHAINING           | send STOP, START and<br>address after last<br>master frame without<br>STOP sent (see note 2)     |
| 0   | 0   | ANY                | NOP                     | no operation (see note 3)                                                                        |

#### Notes to Table 6

- 1. In master-receiver mode, the last byte most be terminated with ACK bit HIGH ("negative-acknowledge"; see I<sup>2</sup>C-bus specification).
- If both STA and STO are set HIGH simultaneously in master mode, a STOP condition followed by a START condition + address will be generated. This allows "chaining" of transmissions without relinquishing bus control.
- 3. All other STA, STO mode combinations not mentioned in Table 6 are NOPs.

The instruction bits are defined as follows:

- STA, STO: These bits control the generation of the I<sup>2</sup>C-bus START condition + transmission of slave address and R/W bit, generation of repeated START condition, and generation of the STOP condition
- ENI: This bit enables the external interrupt output INT, which is generated when the PIN bit is reset.
- ACK: This bit must be set normally to a '1'. This causes the I<sup>2</sup>C-bus controller to send an acknowledge automatically after each byte (this occurs during the ninth clock pulse). The bit must be reset when the I<sup>2</sup>C-bus controller is operating in master/receiver mode, and requires no further data to be sent from the slave transmitter. This causes a negative acknowledge on the I<sup>2</sup>C-bus, which halts further transmission from the slave device.

May 1994





PCF8584

### **FUNCTIONAL DESCRIPTION** (continued)

#### 12C-bus status information

The read-only section consists of I<sup>2</sup>C-bus status information. The functions are as follows:

- STS: When in slave-receiver mode, this flag is asserted when an externally generated STOP condition is detected (only used in slave-receiver mode).
- BER: Bus error. A misplaced START or STOP condition has been detected.
- LRB/AD0: Last Received Bit/Address 0 "General Call" Bit. This dual function status bit holds the value of the last received bit over the I<sup>2</sup>C-bus when AAS = 0. Normally this will be the value of the slave acknowledge; thus checking for slave acknowledgment is done via testing of the LRB bit. When AAS = 1 ("Address As Slave"), the I<sup>2</sup>C-bus controller has been addressed as a slave and this bit will be set if the slave address received was the "general call" address, or if it was the I<sup>2</sup>C-bus controller's slave address.
- AAS: "Addressed As Slave" bit. When acting as slave-receiver, this flag is set when an incoming
  address over the I<sup>2</sup>C-bus matches the value in Own Address register S0', or if the I<sup>2</sup>C-bus "general
  call" address ("00" Hex) has been received.
- LAB: "Lost Arbitration" bit. This bit is set when, in multmaster operation, arbitration is lost to another master on the I<sup>2</sup>C-bus.
- BB: "Bus Busy" bit. This is read-only flag indicating when the I<sup>2</sup>C-bus is in use. A zero indicated that the bus is busy, and access is not possible. This bit is set/reset by STOP/START conditions.

## PIN bit

The PIN bit "Pending Interrupt Not" is a read-only flag which is used to synchronize serial communication. Each time a serial data transmission is initiated (by setting the STA bit in the same register), the PIN will be set automatically. After successful transmission of one byte (9 clock pulses, including acknowledge), this bit will be automatically reset indicating a complete byte transmission. When the ENI bit is also set, the PIN flag triggers an external interrupt via the INT output when PIN is reset. When in receiver mode, the PIN bit is also reset on completion of each received byte. In polled applications, the PIN bit is tested to determine when a serial transmission has been completed. During register transfers the I<sup>2</sup>C-bus controller Data Register SO and its internal shift register (not accessible directly), the I<sup>2</sup>C-bus controller will delay serial transmission by holding the SCL line LOW until the PIN bit becomes set. In receiver mode, the PIN bit is automatically set when the data register SO is read. When the PIN bit becomes set all status bits will be reset, with exception of BB.

May 1994

3-25

7110826 0076311 199



PCF8584

#### Multi-master operations

To avoid conflict between data and repeated START and STOP operations, multi-master systems have some limitations:

- Transmissions requiring a repeated START condition must have identical format among all potential masters for both read and write operations
- For correct arbitration masters may only attempt to send data simultaneously to the same location, if they use the same formats (i.e. number of data bytes, location of the repeated START, etc.). If this condition is designed not to occur, differing formats may be used.

Reset A low-level pulse on the RESET input forces the I<sup>2</sup>C-bus controller into a well-defined state. All flags are reset (zero state), except the PIN flag, which is set. The RESET pin is also used for the STROBE output signal. Both functions are separated on-chip by a digital filter. The reset input signal has to be sufficiently long (minimum 30 clock cycles) to pass through the filter. The STROBE output signal is sufficiently short (8 clock cycles) to be blocked by the filter. For more detailed information on the Strobe function see Special function modes.

### Comparison to the MAB8400 I<sup>2</sup>C-bus interface

The structure of the PCF8584 is similar to that of the MAB8400 series of microcontrollers, but with a modified control structure. Access to all I<sup>2</sup>C-bus control and status registers is done via the parallel-bus port in conjunction with register select input A0, and control bits ESO, ES1 and ES2. The main differences are highlighted below.

#### Deleted functions

The following functions are not available in the PCF8584:

- Always selected (ALS flag)
- Access to the bit counter (BC0 to BC2)
- Full SCL frequency selection (2 bits instead of 5 bits)
- The non-acknowledge mode (ACK flag)
- Asymmetrical clock (ASC flag)

#### Added functions

The following functions either replace the deleted functions or are completely new:

- · Chip clock prescaler
- Assert acknowledge bit (ACK flag)
- Register selection bits (ES1 and ES2 flags)
- Additional status flags
- Automatic interface control between 80XX and 68000-type microprocessors
- Programmable interrupt vector
- Strobe generator
- Bus monitor function
- Long-distance mode (non-1<sup>2</sup>C-bus mode; only for communication between remote parallel-bus processors)

May 1994

3-26

**7110826 0076312 025** 



PCF8584

#### Special function modes

#### Strobe

When the I<sup>2</sup>C-bus controller receives its own address (or the "00" Hex general call address) followed immediately by a STOP condition (i.e. no further data transmitted after the address), a strobe output signal is generated at the RESET/STROBE pin (pin 19). The STROBE signal consists of a monostable output pulse (active LOW), eight clock cycles long (see Fig.10). It is generated after the STOP condition is received, preceded by the correct slave address. This output can be used as a bus access controller for multi-master parallel-bus systems (see Fig.14).

## Long-distance mode

The long-distance mode provides a serial communication link between parallel processors using two or more I<sup>2</sup>C-bus controllers. This mode is selected by setting ES1 to logic 1 while the serial interface is enabled (ESO = 1). In this mode the I<sup>2</sup>C-bus protocol is transmitted over 4 unidirectional lines, SDA, OUT, SCL IN, SDA IN and SCL OUT (pins 2, 3, 4 and 5). These communication lines should be connected to the line drivers/receivers for long distance applications. Specification for long distance transmission is then given by the chosen standard. Control of bus frequency, data transmission etc. is the same as in normal I<sup>2</sup>C-bus mode. After reading or writing data to shift register SO, long-distance mode must be initialized by setting ESO and ES1 to logic 1. Because the interrupt output INT is not available in this operating mode, data reception must be polled.

#### Monitor mode

When the 7-bit Own Address register SO' is loaded with all zeros, the I<sup>2</sup>C-bus controller acts as a passive I<sup>2</sup>C monitor. The main features of the monitor mode are as follows:

- The controller is always selected
- The controller is always in the slave-receiver mode
- The controller never generates an acknowledge
- The controller never generates an interrupt request
- A pending interrupt condition does not force SCL LOW
- Received data is automatically transferred to the read buffer
- Bus traffic is monitored by the PIN bit, which is reset after the acknowledge bit has been transmitted and is set as soon as the first bit of the next byte is detected

May 1994

3-27

7110826 0076313 T61 |



PCF8584

#### **RATINGS**

Limiting values in accordance with the Absolute Maximum System (IEC 134)

| parameter                           | symbol           | min. | max.                  | unit |
|-------------------------------------|------------------|------|-----------------------|------|
| Supply voltage range (pin 20)       | V <sub>DD</sub>  | -0.3 | +7.0                  | V    |
| Voltage range on any input*         | VI               | -0.8 | V <sub>DD</sub> + 0.5 | V    |
| DC input current (any input)        | ±t1              | -    | 10                    | mA   |
| DC output current (any output)      | ±10              | -    | 10                    | mA   |
| Total power dissipation             | P <sub>tot</sub> | -    | 300                   | mW   |
| Power dissipation per output        | Po               | -    | 50                    | mW   |
| Operating ambient temperature range | Tamb             | -40  | + 85                  | °C   |
| Storage temperature range           | T <sub>stg</sub> | -65  | + 150                 | oC   |

<sup>\*</sup> Measured via a 500 Ω resistor.

## Note to the Ratings

Stresses above those listed in accordance with Absolute Maximum System may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating condition for extended periods may affect reliability.

#### HANDLING

Inputs and outputs are protected against electrostatic discharge in normal handling. However, to be totally safe, it is good practice to take normal precautions appropriate to handling MOS devices (see 'Handling MOS Devices').

May 1994





PCF8584

#### CHARACTERISTICS

 $V_{DD}$  = 5 ± 10%;  $V_{SS}$  = 0 V;  $T_{amb}$  = -40 to + 85 °C; unless otherwise specified

| parameter                              | conditions                          | symbol           | min.                | typ. | max.            | unit     |
|----------------------------------------|-------------------------------------|------------------|---------------------|------|-----------------|----------|
| Supply                                 |                                     |                  |                     |      |                 |          |
| Supply voltage range                   |                                     | VDD              | 4.5                 | 5.0  | 5.5             | V        |
| Supply current<br>standby<br>operating | note 1<br>note 2                    | DD1<br>DD2       | _                   | _    | 2.5<br>1.5      | μA<br>mA |
| Inputs                                 |                                     |                  |                     |      |                 |          |
| SCL, SDA                               |                                     |                  |                     |      |                 |          |
| Input voltage LOW                      | note 3                              | V <sub>IL1</sub> | 0                   | -    | 0.8             | V        |
| Input voltage HIGH                     | note 3                              | VIH1             | 2.0                 | -    | V <sub>DD</sub> | V        |
| Input voltage LOW                      | note 4                              | VIL2             | 0                   | -    | 0.3VDD          | V        |
| Input voltage HIGH                     | note 4                              | V <sub>IH2</sub> | 0.7 V <sub>DD</sub> | -    | V <sub>DD</sub> | V        |
| Resistance to V <sub>DD</sub>          | T <sub>amb</sub> = 25 °C;<br>note 5 | Ri               | 25                  | -    | 100             | kΩ       |
| Outputs                                |                                     |                  |                     |      |                 |          |
| Output current LOW                     | VOL = 0.4 V                         | IOL              | 3.0                 | _    | _               | mA       |
| Output current HIGH                    | V <sub>OH</sub> = 2.4 V;<br>note 6  | -10н             | 2.4                 | _    | _               | mA       |
| Leakage current                        | note 7                              | ± 1LO            | -                   | -    | 1               | μΑ       |

## Notes to the characteristics

- 1. 22 k $\Omega$  pull-ups on D0 to D7; 10 k $\Omega$  pull-ups on SDA, SCL,  $\overline{RD}$ ;  $\overline{RESET}$  tied to  $V_{SS}$ ; remaining pins open-circuit.
- 2. Same as note 1, but CLK waveform with 50% duty factor at 12 MHz.
- 3. CLK, IACK, AO, CS, WR, RD, RESET, TTL level inputs.
- 4. SDA, SCL, D0 to D7, CMOS level inputs.
- 5. CLK, TACK, AO, CS, WR.
- 6. D0 to D7.
- 7. D0 to D7 3-state, SDA, SCL, INT, RD, RESET.

May 1994

3-29

**■ 7110826 0076315 834 ■** 



PCF8584

## **Timing specifications**

All the timing values are valid within the operating supply voltage and ambient temperature range and refer to  $V_{IL}$  and  $V_{IH}$  with an input voltage swing of  $V_{SS}$  to  $V_{DD}$ .

| parameter                   | symbol         | min. | typ. | max. | unit |
|-----------------------------|----------------|------|------|------|------|
| I <sup>2</sup> C-bus timing |                |      |      |      |      |
| SCL clock frequency         | fSCL           | -    | -    | 100  | kHz  |
| Tolerable bus spike width   | tsw            | -    | -    | 100  | ns   |
| Bus free time               | †BUF           | 4.7  | -    | -    | μs   |
| Start condition set-up time | tsu; STA       | 4.7  | -    | -    | μs   |
| Start condition hold time   | tHD; STA       | 4.0  | -    | _    | μs   |
| SCL LOW time                | tLOW           | 4.7  | -    | -    | μs   |
| SCL HIGH time               | tHIGH          | 4.0  | -    | -    | μs   |
| SCL and SDA rise time       | t <sub>r</sub> | -    | -    | 1.0  | μs   |
| SCL and SDA fall time       | tf             | -    | -    | 0.3  | μs   |
| Data set-up time            | tSU; DAT       | 250  | -    | -    | ns   |
| Data hold time              | tHD; DAT       | 0    | -    | -    | ns   |
| SCL LOW to data out valid   | tVD; DAT       | -    | -    | 3.4  | μs   |
| Stop condition set-up time  | tsu; sto       | 4.0  | _    | -    | μs   |

May 1994

3-30

**7110826 0076316 770** 



PCF8584

## Parallel interface timing (see Figs 3 to 10)

All the timing limits are valid within the operating supply voltage and ambient temperature range and

refer to V<sub>IL</sub> and V<sub>IH</sub> with an input voltage swing of V<sub>SS</sub> to V<sub>DD</sub>.  $C_L = 100 \ pF$ ,  $R_L = 1.5 \ k\Omega$  (connected to V<sub>DD</sub>) for open-drain and high-impedance outputs, where applicable (for measurement purposes only).

| parameter                               | figure  | symbol           | min. | typ.     | max.       | unit |
|-----------------------------------------|---------|------------------|------|----------|------------|------|
| Clock rise time                         | 3       | t <sub>r</sub>   | _    | _        | 6          | ns   |
| Clock fall time                         | 3       | tf               | -    | _        | 6          | ns   |
| Input clock period<br>(50% duty factor) | 3       | tCLK             | 83   | _        | 333        | ns   |
| CS set-up to RD, WR LOW                 | 4       | tsU1             | 30   | _        | _          | ns   |
| CS hold from RD, WR HIGH                | 4       | tHD1             | 0    | _        | _          | ns   |
| A0 set-up to RD, WR LOW                 | 4       | tsu2             | 10   | _        | _          | ns   |
| A0 hold from RD, WR HIGH                | 4       | tHD2             | 20   | _        | _          | ns   |
| WR pulse width                          | 4       | tw1              | 230  | _        | _          | ns   |
| RD pulse width                          | 4       | tw2              | 230  | _        | _          | ns   |
| Data set-up before WR HIGH              | 4       | tsu3             | 150  | _        | _          | ns   |
| Data valid after RD LOW                 | 4       | tVD              | -    | 110      | 180        | ns   |
| Data hold after WR HIGH                 | 4       | tHD3             | 30   | -        | _          | ns   |
| Data bus floating after RD HIGH         | 4       | tFL              | 70   | _        | _          | ns   |
| A0 set-up to CS LOW                     | 5 and 6 | tSU4             | 30   | _        | _          | ns   |
| R/WR set-up to CS LOW                   | 5 and 6 | t <sub>SU5</sub> | 30   | _        | _          | ns   |
| Data valid after CS LOW                 | 5       | tVD1             | -    | 110      | 180        | ns   |
| DTACK LOW after CS LOW                  | 5 and 6 | t <sub>d1</sub>  | -    | 3tCLK+75 | 3tCLK+ 150 | ns   |
| A0 hold from CS HIGH                    | 5 and 6 | tHD4             | 0    | _        | _          | ns   |
| R/WR hold from CS HIGH                  | 5 and 6 | tHD5             | 0    | _        | _          | ns   |
| Data hold after CS HIGH                 | 5       | tHD6             | 160  | -        | _          | ns   |
| DTACK HIGH from CS HIGH                 | 5 and 6 | t <sub>d2</sub>  | _    | 100      | 120        | ns   |
| Data hold after CS HIGH                 | 6       | tHD7             | 0    | _        | _          | ns   |
| Data set-up to CS LOW                   | 6       | tsu6             | 0    | _        |            | ns   |
| INT HIGH from IACK LOW                  | 7 and 8 | t <sub>d3</sub>  | -    | 130      | 180        | ns   |
| Data valid after IACK LOW               | 7 and 8 | tVD2             | _    | 140      | 190        | ns   |

May 1994

3-31

**7110826 0076317 607** 



PCF8584

## Parallel interface timing (continued)

| parameter                 | figure  | symbol          | min.               | typ.                  | max.       | unit |
|---------------------------|---------|-----------------|--------------------|-----------------------|------------|------|
| TACK pulse width          | 7 and 8 | tw3             | 230                | -                     | _          | ns   |
| Data hold after IACK HIGH | 7 and 8 | tHD8            | 100                | _                     | _          | ns   |
| DTACK LOW from IACK LOW   | 8       | t <sub>d4</sub> | _                  | 3tCLK+75              | 3tCLK+ 150 | ns   |
| DTACK HIGH from IACK HIGH | 8       | t <sub>d5</sub> | _                  | 120                   | 140        | ns   |
| Reset pulse width         | 9       | tw4             | 30t <sub>CLK</sub> | -                     | _          | ns   |
| Strobe pulse width        | 10      |                 | 8tCLK              | 8t <sub>CLK</sub> +90 | _          | ns   |

### Notes to parallel interface timing

- A minimum of 6 clock cycles must elapse between consecutive parallel-bus accesses when the I<sup>2</sup>C-bus controller operates at 8 or 12 MHz. This may be reduced to 3 clock cycles for lower operating frequencies.
- 2. After reset the chip clock default is 12 MHz.



Fig.3 Clock input timing.

May 1994

3-32

7110826 0076318 543



PCF8584

## **Timing diagrams**





Fig. 4 Bus timing (80XX-mode); (a) write cycle, (b) read cycle.

May 1994

3-33

7110826 0076319 48T



PCF8584



Fig.5 Bus timing; 68000-mode read cycle.

May 1994

7110826 0076320 1T1 **\*\*\*** 



PCF8584



Fig.6 Bus timing; 68000-mode write cycle.

May 1994

7110856 0036357 038

PCF8584



Fig.7 Interrupt timing; 80XX-mode.



Fig.8 Interrupt timing; 68000-mode.

May 1994 3-36 7110826 0076322 T74 ==



PCF8584





Fig.9 Reset timing.



Fig.10 Strobe timing.

May 1994

3-37

■ 7110826 0076323 900 **■** 



PCF8584

### **APPLICATION INFORMATION**



Fig.11 Application diagram using the MAB8048/MAB8051.



Fig.12 Application diagram using the SCN68000.

May 1994

3-38

7110826 0076324 847



I-O-Dua controller



Fig.13 Application diagram using the 8088.

May 1994

7110826 0076325 783



PCF8584



Fig.14 STROBE as bus access controller.



Purchase of Philips' I<sup>2</sup>C components conveys a license under the Philips' I<sup>2</sup>C patent to use the components in the I<sup>2</sup>C-system provided the system conforms to the I<sup>2</sup>C specifications defined by Philips.

May 1994

7110826 0076326 61T **=**